草庐IT

python - 使用python从子进程读取输出

全部标签

ruby - 如何打印 Ruby 1.9 进程的运行时堆栈跟踪?

有什么方法可以打印Ruby1.9.x进程的运行时堆栈跟踪吗?我知道Ruby1.8有一个名为pstack的实用程序,但该项目似乎在几年前就被放弃了:https://github.com/ice799/pstack.Ruby1.9是否存在类似的东西?非常感谢!编辑:我有兴趣使用外部工具生成堆栈跟踪(不在与Ruby进程相同的内存空间中运行)。正如@mosch所指出的,Kernal#caller方法在正在运行的Ruby进程中运行。您甚至可以构建对捕获进程信号并打印堆栈跟踪的Ruby代码的支持:Signal.trap("SIGTERM"){pcaller}引用:http://www.ruby-d

ruby - 开始使用 MacRuby 和 Xcode 4.2

我最近想开始使用MacRuby。我已经安装了Xcode4.2和MacRuby,但显然我遗漏了一些东西。到目前为止,在我发现的每个教程中都说,我必须从Xcode模板中选择“MacRuby应用程序”……但是没有这样的条目可用。我试过0.10和几天前发布的每晚版本。我查看了MacRuby的安装位置,我找到了Xcode3.0的模板……我必须使用这些模板吗?如何将它们导入Xcode4.2?在开始之前,我还想知道,从MacRuby开始是否安全?乍一看,我认为"is",因为有新的MacRuby书籍可用——但MacRuby网站上似乎没有太多事件(去年3月的最后一篇博客文章?)……根据我的经验,这可能是

ruby - 如何在 ruby​​ 模板中输出排序哈希

我正在为我们的一个内联应用构建一个配置文件。它本质上是一个json文件。我在让puppet/ruby1.8每次都以相同的方式输出哈希/json时遇到了很多麻烦。我正在使用但是在输出人类可读的内容时,它并不能保证每次都是相同的顺序。这意味着Puppet会经常针对相同的数据发送更改通知。我也试过每次都会生成相同的数据/订单。当数据具有嵌套数组时就会出现问题。data=>{beanstalkd=>["server1",]}成为"beanstalkd":"server1",代替"beanstalkd":["server1"],我断断续续与这个问题斗争了几天,所以需要一些帮助

ruby - Ruby 守护进程中的错误文件描述符

在MacOSXLion上使用Rubyv1.8.7和Daemonsv1.1.8,我试图编写一个消费者进程并让它作为守护进程运行:#config[:name]=>'idx_my_delete_consumer'#config[:daemon]=>{:multiple=>false,#:backtrace=>true,#:dir_mode=>:normal,#:log_dir=>'/Users/pprakash/consumer.log',#:monitor=>true,#:dir=>'/Users/pprakash/pids'}Daemons.run_proc(config[:name],

ruby-on-rails - 使用 Gerrit 部署 Ruby on Rails 数据库

我正在考虑在我的下一个项目中使用RubyonRails。了解Rails网站的部署很容易理解(听起来我会使用PhusionPassenger)但现在我正试图找出数据库。我看到很多关于“数据库迁移”的内容,它允许我使用ruby​​代码更新数据库。我还看到我被允许创建这些迁移的up和down变体。但是,我只能理解这是如何在一个方向上干净利落地工作的。想象一下,如果我突然说“颜色列不能为空”。因此,up将使其成为必需项并为所有NULL条目提供默认值。但是向下会做什么呢?如果您关心它与它的开始方式相同,则不能将默认值设置回NULL。这对于发布到生产环境来说并不重要。这可能只会在一个方向上完成(在

ruby-on-rails - 检查我是否在 delayed_job 进程中

我有一个Rails应用程序,我在其中使用delayed_job。我想检测我是否在delayed_job进程中;像ifin_delayed_job?#dosomethingonlyifitisadelayed_jobprocess...else#dosomethingonlyifitisnotadelayed_jobprocess...end但是我不知道怎么办。这是我现在使用的:IN_DELAYED_JOB=beginbasename=File.basename$0arguments=$*rake_args_regex=/\Ajobs:/(basename=='delayed_job')

ruby-on-rails - 使用 rspec 测试 rails 而不需要运行所有初始化程序?

假设您正在开发一个Rails应用程序,它有很多初始化程序,这些初始化程序会在启动时调用各种外部系统。当使用rspec-rails运行rspec时,它会运行所有初始化器,即使您的测试很简单,不需要rails基础设施。我知道您可以使用Spork只产生一次这种成本,但有没有办法完全不产生它?仅仅为了一个简单的PORO规范而加载所有rails似乎很愚蠢。 最佳答案 不要使用spork。如果您想使用预加载器,请查看zeus或spring。您不需要加载整个Rails环境来测试不依赖于Rails的东西。这可以很简单,例如明确要求每个规范所需的依赖

ruby - 使用 ruby​​ 创建 OKTA JIRA 登录

我需要通过REST使用Okta向JIRA进行身份验证,我该如何在ruby​​上执行此操作?有可能的?我以前从来没有这样做过,我只想从JIRA中的票证中获取附件 最佳答案 事实证明,您只需将登录用户(例如您自己)的JSESSIONIDcookie发送到RESTAPI。您可以从浏览器手动获取cookie,或者编写浏览器扩展来获取cookie,然后使用该cookie的值作为命令行参数调用您的Ruby脚本。对于Chrome,您可以为此使用ChromeNativeMessaging。 关于ruby

ruby-on-rails - 使用 API 获取数据时,最好将该数据存储在另一个数据库中,还是最好在需要时继续获取该数据?

这个问题在这里已经有了答案:CachingcallstoanexternalAPIinarailsapp(1个回答)关闭6年前。我正在使用TMDBapi来获取电影标题和发行年份等信息,但我想知道我是否需要创建一个额外的数据库来在本地存储所有这些信息,而不是继续使用api获取信息?例如,我是否应该创建一个电影模型并调用:film.title并通过这样做访问存储有标题的本地数据库,或者我调用:Tmdb::Movie.detail(550).title然后再调用一次api?

ruby-on-rails - 如何使用 rspec 模拟/伪造文件的存在?

这是我的:it"shouldbeabletogetavaliddirectorypath"do@asset.some_file_path.should=="/something/test.jpg"end问题是如果不存在文件,some_file_path返回“/not_here_yet.jpg”。defsome_file_pathifFile.exists(self.my_image_path)returnmy_image_pathelsereturn"/not_here_yet.jpgendend我真的不想在我的测试中创建一个新文件。我有办法伪造该文件的存在吗?我在想一些事情:it"s